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(54) Method and system for remotely browsing objects 



(57) Remote access to objects such as beans is pro- 
vided by mapping objects onto an HTML page at the 
networl< station at which the objects are located. An 
HTML generator running on the same virtual machine 
is used dynamically to map the beans onto the HTML 
page. Remote access for browsing and modifying the 



object is then possible using a web browser supporting 
HTTP or HTML protocols without having to specially 
modify an object to permit access, for example by the 
provision of remote access code in the object. An appli- 
cation for remote bean access is in the context of a net- 
work agent for a network management system. 
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Description 

BACKGROUND OF THE INVENTION 

[0001] The invention relates to the control and/or ac- 
cess of objects. In particular objects known as beans. 
Beans, for example JavaBeans components (Java- 
Beans is a trademark of Sun Microsystems, Inc."), are 
reusable software components which can be manipulat- 
ed visually in a builder tool (e.g. an editor or graphical 
user interface builder (GUI builder)). An example of a 
builder tool is the JavaBeans Development Kit. Further 
details about beans can be found in many different 
works, for example In a book entitled Mastering Java- 
Beans by Lawrence Vanhelsuw6 published by Sybex 
(ISBN 0-7621 •2097-0). This is just one example of many 
broadly equivalent books on the market having "Java- 
Beans' in the title and describing the JavaBeans. Many 
of these works, including the book Mastering Java- 
Beans, supply the Bean Development Kit mentioned 
above. 

[0002] Beans vary in functionality, but they typically 
share certain common defining features providing a set 
of properties, a set of methods and support for events 
and for introspection, also known as reflection. The 
properties allow beans to be manipulated programmat- 
ically and support customization of the bean. The meth- 
ods implement the properties: The support for events 
enables beans to fire events and define the events 
which can be fired. The support for introspection ena- 
bles the properties, events and methods of the bean to 
be inspected externally. 

[0003] However, beans can generally only be control- 
led and manipulated within the virtual machine environ- 
ment in which the beans exist. US patent 5,31 5,703 and 
US patent 5,367,633 describe object-based systems 
where change notification functions are provided. How- 
ever, these patents describe stand-alone systems. 
[0004] It woukJ be desirable to be able to access and 
control any bean remotely, for example over a network. 
However, this has not been possible without actually in- 
cluding appropriate methods within the beans them- 
selves to expose the methods required. However, it is 
not desirable to have to specifically adapt beans to per- 
mit remote access. It would be desirable to be able re- 
motely to access, control and modify any beans remote- 
ly without pre-modification. 

[0005] Accordingly it is an object of the invention to 
address this problem. 

SUMMARY OF THE INVENTION 

[0006] Particular and preferred aspects of the inven- 
tion are set out in the accompanying independent and 
dependent claims. Features of the dependent claims 
may be combined with those of the independent claims 
as appropriate and in combinations other than those ex- 
plicitly set out in the claims. 



[0007] In accordance with a first aspect of the inven- 
tion, there is provided a computer-implemented method 
of accessing from a client machine an object at a remote 
machine via a telecommunications network, the method 
5 comprising steps of: 

a) registering at least one object at the remote ma- 
chine; 

b) generating a machine page at the remote ma- 
chine, which page contains at least one registered 
object; and 

b) browsing the object via a network adaptor and 
the machine page at the remote machine using a 
browser at the client station. 

[0008] By associating an object with a machine page, 
a browser can be used at a client machine remotely to 
access the object at the machine, or virtual machine at 
which the machine page is provided. The act of regis- 
tration of the object is arranged to permit remote access 
to the object via the network adaptor without needing to 
pre-modrfy the object or to require the object to include 
its own internal remote access methods. 
[0009] The invention finds particular application to 
providing remote access to an object in the form of a 
bean comprising a set of properties, a set of methods 
for performing actions, and support for events and for 
introspection. Access to a bean via the network adaptor 
for the extraction of bean methods utilises this introspec- 
tion. The framework and/or the network adaptor are 
preferably also implemented as beans, providing a flex- 
ible virtual machine structure. 
[0010] Preferably, the remote machine comprises an 
agent framework and. in step (b), the network adaptor 
queries the framework to identify the registered object. 
This provides a flexible and extensible arrangement for 
permitting access to objects at a remote machine. This 
provkies a flexible method for adding new beans on de- 
mand. Indeed, as a further refinement, the preferred em- 
bodiment employs a framework which comprises an as- 
sociated repository object and step (a) comprises reg- 
istering the object and/or the network adaptor with the 
repository object. The framework and/or the networic 
adaptor can also be beans. Step (b) can comprise ex- 
tracting bean methods by introspection. 
[0011] In a preferred embodiment the machine page 
is an HTML page at the virtual machine where the beans 
or objects are located and the network adaptor is an 
HTML adaptor at the machine. The bean can be repre- 
sented as an HTML table wherein: 

a first column contains a property name; 
a second column contains a property type; 
a third column contains the access right (read/ 

write); and 

a fourth column contains a property value. 
[0012] In other embodiments, methods and/or sup- 



25 



30 



35 



40 



45 



SO 



2 



12/15/2006, EAST Version: 2.1.0.14 



3 



EP 0 908 816 A2 



4 



port for events could also be provided in the HTML table. 
[0013] The invention finds particular application to a 
network management system wherein the object to 
which access is sought is a managed object bean within 
a managed machine. 

[0014] The object can be one of a set of beans at the 
remote machine, whereby step (d) can comprise: 

displaying at a client machine representations of 
beans at the remote machine which are modifiable 
remotely from the client machine; 
responding to user selection at the client machine 
ot a displayed bean representation to display at the 
client machine bean properties which are remotely 
modifiable; and 

responding to user input at the client machine re- 
motely to modify selected parameters of the bean. 

[0015] In accordance with another aspect of the in- 
vention, there is provided a computer-implemented 
method of accessing an object at a remote machine via 
a telecommunicattons network, the method comprising 
steps of: 

mapping the object to an externally accessible ma- 
chine page at the remote machine; and 
browsing the object via the machine page using a 
browser. 

[0016] In accordance with a further aspect of the in- 
vention, there is provided a computer system accessible 
remotely via a telecommunications network, the compu- 
ter system comprising a mapping mechanism config- 
ured to map an object to an externally accessible ma- 
chine page at the remote machine, whereby the object 
is accessible externally via the machine page using a 
browser. 

[0017] The invention further provides a software sys- 
tem on at least one storage device for enabling remote 
access to an object via a telecommunications network, 
the system comprising a nnapping mechanism config- 
ured to map an object to an extemally accessible ma- 
chine page, whereby the object can be accessed via the 
machine page using a browser. 

BRIEF DESCRIPTION OF THE DRAWINGS 

[001 8] Exemplary embodiments of the present inven- 
tion will be described hereinafter, by way of example on- 
ly, with reference to the accompanying drawings in 
which like reference signs relate to like elements and in 
which: 

Figure 1 is a schematic representation of three sta- 
tions connected via a telecommunications network; 
Figures 2 and 2A form a schematic representation 
of a computer server for a station of Figure 1 ; 
Figure 3 is a schematk; representation of an agent 



for a managed station; 

Figure 4 is an alternative representatk>n of the 
agent of Figure 3; 

Figure 5 is an example of a configuration for an 

5 agent; 

Figure 6 is a flow diagram illustrating operations us- 
ing an agent as shown in Figure 5; 
Figure 7 is an example of a configuration of a man- 
agement system; 

^0 Figure 8 is another example of a configuration of a 
nnanagement system; 

Figure 9 illustrates an aspect of the creation of the 
configuration of Figure 8; 

Figure 10 is a flow diagram illustrating operations 
of the system of Figure 8; 
Figure 111s a flow diagram illustrating the operation 
of a naming sen/lce; 

Figure 1 2 is a flow diagram Illustrating the operation 
of the creation of a generic agent; 
Figures 13 and 14 illustrate alternative operatbns 
of a compiler; 

Figures 1 5A and 1 5B are used to Illustrate the effect 
of compiling a management bean; 
Figures 16A and 16B are also used to illustrate the 
effect of compiling a management bean; and 
Figure 17 is a flow diagram illustrating steps in gen- 
erating a management system. 



[0019] Figure 1 is a schematic representation of a 
multi-station network based system 1 with three sta- 
tions, or nodes, or machines 3, 4 and 5 connected via 
a network 2. The network 2 can be based on a public 
switched telephone network and/or a local area network 
and/or a dedicated network connecting computer and 
other equipment within a local area and/or over a wider 
area and/or an open network such as the Internet or an 
intranet, or combination thereof or indeed any other type 
of telecommunications network which can support the 
exchange of telecommunications management infor- 
mation. The network can have any desired structure, 
such as a level structure, a pyramidal hierarctiy, etc. 
[0020] Any one or more of the stations 3, 4 or 5 can 
be configured as a network management station. In the 
example shown in Figure 1 , it is assumed that station 3 
is a management statbn and stations 4 and 5 are man- 
aged stations. It will be appreciated that any number of 
management stations and managed stations may be 
provided and that the three stations of Figure 1 are for 
illustrative purposes only. Also, the managing and man- 
aged functions could be Interchanged or indeed both 
managing and managed functions could be supported 
at one and the same station. 

[0021] The stations can take on many forms. For the 
purposes of illustration it is assumed that both comprise 
computer workstations. Figure 2 is a schematk: repre- 
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sentation of the configuration of a computer workstation. 
As Illustrated In Figure 2, this Is Imptemented by a server 
computer 10 comprising a system unit 11 with a display 
8, keyboard and other input devices 9. Figure 2A is a 
schematic block representation of aspects of the con- 
tents of the system unit 11. As illustrated In Figure 2A, 
the system unit includes a processor 17, memory 18, 
magnetic and/or optical disk drives 13 and 14, and a 
communications adaptor 16 for connection to one or 
more telecommunication lines 15 for connection to the 
telecommunk:ations network 2. As Illustrated in Figure 
2A, the components of the system unit are connected 
via a bus arrangement 1 9. It will be appreciated that Fig- 
ures 2/2A are a general schematic representation of one 
possible configuration for a server computer for forming 
a router. It will be appreciated that many alternative con- 
figurations could be provided. 

[0022] Where the workstation implements a manage- 
ment station, management application or applications 
and interface structures are typically provided by soft- 
ware which is stored in the memory of the workstation 
and executed by the processor of the workstation. 
[0023] Where the workstation Implements a managed 
station, an agent is responsive to remote management 
requests via the network from the management applica- 
tions to provide an interface to managed objects at the 
managed stations. The agent and managed object 
structures are typically provided by software which is 
stored in the memory of the workstation and executed 
by the processor of the workstation. 
[0024] The objects typically comprise parameters and 
methods used to OKxiel a piece of equipment, a compo- 
nent of that equipment, an operation of the equipment 
or a component or resource thereof, and so on. 
[0025] The management of a telecommunications 
network requires applications of various sizes and com- 
plexities. Heavy managers, middle managers, extensi- 
ble agents, smart agents and appliances all have a role 
in the management of a telecommunications network. A 
network management system incorporating the present 
invention provides an extensible agent framework al- 
lowing all of these different application types to be built 
on the same architecture. This extensible agent frame- 
work Is provided by a component of the network man- 
agement system. Alternative terms for the extensible 
agent framework in this context could be a "dynamic 
framework" or "open framework" or "runtime compo- 
nent", although the terms "framework" or "extensible 
agent framework" will be used herein. 
[0026] The network management system is supplied 
with a set of core management services. A choice can 
be made from this set of sen/ices, and it can be extended 
to develop specific applications. Different services are 
loaded statically or dynamically into the framework to 
meet the requirements of a particular application. 
[0027] A managed object in an example of a network 
agent incorporating the present invention is preferably 
implemented as a bean, more preferably a JavaBeans 



component. A bean (and a JavaBeans component) is a 
reusable software cornponent which can be manipulat- 
ed visually in a builder tool (e.g. an editor or graphical 
user interface builder (GUI builder). An example of a 
s builder tool is the JavaBeans Devebpment Kit. Beans 
vary in functionality, but they typically share certain com- 
mon defining features providing a set of properties, a 
set of methods for performing actions, and support for 
events and for introspection. The properties allow beans 
to be manipulated programmatically and support cus- 
tomization of the bean. The methods implement the 
properties. The support for events enables beans to fire 
events and define the events which can be fired. The 
support for introspection enables the properties, events 
and methods of the bean to be inspected from external- 
ly. Operations such as GET, SET. ACTION, CREATE 
and DELETE can be supported. 
[0028] A managed object in the agent is manageable 
as soon as it is registered with the framework. This ar- 
rangement enables an agent developed in accordance 
with this network management system to be managea- 
ble with minimal impact on the design of the agent. 
[0029] As indicated above, an example of the network 
management system uses the JavaBeans component 
model, thereby easing the development of applteations. 
In this example, all of the core management services 
are provided as JavaBeans components. Thus access 
can be had to them using a Java application builder, 
such as the well known JavaBeans Development Kit. 
f\/1anaged objects are developed as JavaBeans compo- 
nents. A JavaBeans component in the network manage- 
ment system agent can be accessed locally or remotely. 
This means that when developing managed objects with 
the network management system, it is not necessary to 
know to which communications protocol the managed 
object will be accessed. 

[0030] The network management system simplifies 
the development of extensible agents. A set of core 
management services that the network management 
system provides can be extended and loaded into ari 
agent while it is running. Most of the core management 
services are optional. This means that an agent devel- 
oped using the network management system need only 
implement the sen/ice It uses. This feature enables the 
development of agents of differing sizes and complexi- 
ties. 

[0031] Agents developed using the network manage- 
ment system are also smart agents. A smart agent pro- 
vides the servrces needed to process management re- 
quests. In a smart agent, much ot the processing can 
be done locally in the agent itself, reducing the load on 
the network connection between the agent and manag- 
ing system. 

[0032] Figure 3 illustrates an aspect of the architec- 
ture of a network management system agent, including 
the relationships between the components of the net- 
work management system. Figure 3 also shows the re- 
lationship between the network management system 
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agent and management applications. 
[0033] As shown in Figure 3, the network manage- 
ment system agent consists of a number of components 
inside a Java virtual machine (VM). These include: 

m-beans 29; 
the framework 24; 

core management services 25, 26, 27, 28; 
managed objects adaptor sen/ers 30. 32, 34, 36 
and 38. 

These components will be described In more detail be- 
low. 

[0034] A managed object is a software abstraction 
of a resource that is controlled and monitored by an 
agent. A managed object (eg. 28) is referred to as a 
management bean or m-bean. In an example of the net- 
work management system, all m-beans are implement- 
ed as JavaBeans components. Therefore, these can be 
accessed using a conventional Java application builder, 
such as the JavaBeans Development Kit mentioned 
earlier. 

[0035] As for any other managed object, an m-bean 
has a set of properties, can perform a set of actions, and 
can emit a set of notifications or events. The network 
management system enables a distinction to be made 
between a read-only and a read-write property in an m- 
bean. 

[0036] An m-bean is manageable as soon as it is reg- 
istered with the framework 24. When an m-bean is reg- 
istered, an object name is associated with it. The object 
name uniquely identifies the m-bean within the m-bean 
repository (see below). It enables a management appli- 
cation to identify the m-bean on which it is to perform a 
management operation. The object name of an m-bean 
is an arbitrary name that does not depend in any way 
on how the m-bean Is Implemented. 
[0037] The framework 24 controls the management 
services and m-beans of an agent 20 are loaded into 
the framework 24. The framework, or runtime compo- 
nent. 24 is a JavaBeans component which comprises a 
set of properties, a set of methods for performing ac- 
tions, and support for events and for introspection. The 
properties Include getter and setter properties. The 
methods include methods to implement the getter and 
setter properties. The framework is also able to effect 
add object and remove object functions. 
[0038] Whenever an agent 20 is requested to perform 
a management operation received through a network 
adaptor, the framework 24 calls the appropriate service 
to perform the requested operation. The framework 24 
also handles communications between m-beans 28 and 
the managed object adaptor senders 30-38. An m-bean 
can query the framework 24 to obtain information on oth- 
er m-beans 28 loaded into the same instance of the 
framework 24. Only one instance of the framework 24 
is permitted within a virtual machine 22. 
[0039] The network management system provides a 



number of core management sen^lces. In an example 
of the system, the core management services are de- 
fined as Java interfaces. The core management servic- 
es are optional. This means that an agent developed 

s using the network management system need only im- 
plement the sen/ices it uses. The core management 
services can be registered as m-beans. which allows 
some management operations to be formed on them for 
tuning their behaviour. 

10 [0040] In the preferred example of the system, the 
core management sen/ices are provided as JavaBeans 
components. It Is therefore possible to access them us- 
ing a conventional Java application builder, such as the 
JavaBeans Development Kit mentioned earlier. 

IS [0041] A number of the core management sen/ices 
are now to be described. 

[0042] The m-bean repository service 27 obtains 
pointers to m-beans. Each time an m-bean is registered 
with the framework 24, the framework 24 calls the m- 

20 bean repository service 27 to store the identity of the m- 
bean. A name is associated with an m-bean. When que- 
rying the m-bean repository 27, agent and manager ap- 
plications can identify an m-bean by its name. Different 
implementations of the m-bean repository sen/ice 27 

25 are possible. One implementation uses a relational da- 
tabase for storing persistent m-beans, whereas another 
implementation employs simple memory for storing 
non-persistent m-beans. 

[0043] Bearing in mind the structure provided by the 
30 repository unit, an alternative representation of the re- 
lationship between components of the agent is illustrat- 
ed in Figure 4. This takes account of the registration of 
the beans for the managed object adaptor sen/ers. the 
management services and the managed objects with 
55 the m-bean repository sen/ice bean. 

[0044] A filtering service 29 selects m-beans to be 
the subject of a management operatbn. Selection is 
based on the presence and values of specific attributes. 
For example, a filter could select ail the m-beans for 
40 which the attribute color is set to red. 

[0045] A metadata service 25 provides infornriation 
on the structure of an m-bean. For example, the frame- 
work 24 queries the metadata service 25 to access 
methods for getting and setting up a property within an 
^ m-bean. The metadata service 25 is based on the Re- 
flection API provided by the JavaBeans Development 
Kit for performing introspection. 
[0046] A dynamic class loading sen/ice loads new 
classes into the framework 24. A new class is loaded 
so when the remote entry requests the creation of instanc- 
es of a class that is not loaded into the framework 24. A 
new class can be loaded from a remote class server. 
The dynamic loading sen/ice also enables core man- 
agement sen^ices to be added to a network manage- 
rs ment system agent while it is mnning. For example, an 
agent could be started without a filtering service. Then, 
later on, the filtering service could be added dynamically 
to the agent when it Is required. 
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[0047] An access control service can be provided 
to control access to m-beans. Before attempting to per- 
form a management operation on an m-bean, the frame- 
work 24 can be arranged to query the access control 
sen/ice to verify that the operation is valid. 
[0048] An event service can be provided to receive 
event reports from m-beans and to fonA^ard them to any 
entity that has requested to receive them. 
[0049] A relationship service can be provided to en- 
able relationships between m-beans to be defined when 
they are required. The relationships do not need to be 
defined in advance. Information on the relationships be- 
tween m-beans is not stored with the m-beans them- 
selves, but can be obtained from the relationship serv- 
ice. 

[0050] A dynamic native library loading service 

can be provided for loading native code into the frame- 
work 24. A native library can be loaded when a new 
class that includes native code is loaded. The library 
loaded depends on the hardware platform and operating 
system on which the framework is running. The native 
library can be loaded from a remote entity. 
[0051] There now follows a description of the man- 
aged object adaptor servers 30-38. 
[0052] A managed object adaptor server is a proto- 
col adaptor that provides an abstraction of a communi- 
cations protocol. Each managed object adaptor server 
provides access to m-beans through a particular com- 
munications protocol. A managed object adaptor sen/er 
enables management applications to perform manage- 
ment operatbns on a network management system 
agent. 

[0053] For a network management system agent to 
be manageable, it is connected via at least one man- 
aged object adaptor server However, a network man- 
agement system agent can be connected to any number 
of managed object adaptor senders, allowing it to be 
queried by remote management applications that use 
different protocols. 

[0054] The network management system provides 
managed object adaptor sen/ers for standard and pro- 
prietary protocols. 

[0055] For example, managed object adaptor sen/ers 
can be provided for one or more of the standard proto- 
cols: HTMUHTTP; SNMP; and CORBA, by way of ex- 
ample. 

[0056] The managed object adaptor servers for 
standard protocols communicate directly with the man- 
agement applications that use them. 
[0057] For example, an HTML/HTTP managed object 
adaptor server enables a user to use a web browser to 
view management information contained In m-beans 
and to perform management operations on a network 
management system agent. The HTTP/HTML managed 
object adaptor sen/er obtains management information 
from m-beans and generates HTML pages representing 
this management information. 
[0058] An SN M P managed object adaptor server can 



be arranged to use a specialty defined SNMP manage- 
ment information base (MIS) to enable the SNMP man- 
ager to perform management operations on a network 
management system agent. 
5 [0059] The network management system can also be 
arranged to provide managed object adaptor sen/ers for 
one or more of the following proprietary protocols: RMI; 
Java/HTTP; and Secure Sockets l-ayer (SSL), In one 
example of the network management system, a man- 
10 aged object adaptor client offers a Java API . According- 
ly, any management application that uses a managed 
object adaptor client will be written in Java language. 
[0060] Agents developed using the network manage- 
ment system can be managed using different commu- 
15 nications or management protocols. To be managed us- 
ing a standard management protocol, a network man- 
agement system agent needs to be connected to the 
managed object adaptor server for that protocol. The 
managed object adaptor sen/ice for standard protocols 
communicates directly with the management applica- 
tions that use them. 

[0061] An example of this structure, using the agent 
representation of Figure 4, is shown in Figure 5, where 
the agent is accessed by means of a web browser 46. 
Here an HTML adaptor allows beans to be mapped to 
an HTML page. The use of a protocol such as HTML 
enables the browser 46 at the client station 90 to browse 
beans at the remote station 20 and access and where 
necessary modify them using conventional web browser 
functions. In accordance with the structure shown in Fig- 
ure 4, the repository service 27 is registered with the 
framework 24, and the HTML adaptor 34 and the bean 
(s) 29 are registered with the repository service, where- 
by the bean(s) are effectively registered with an HTML 
page supported by the HTML adaptor 34. In Figure 5 
like reference numerals relate to like features of the ar- 
rangement shown in Figure 4. 
[0062] Figure 6 is a flow diagram illustrating steps for 
enabling the modification of properties of the beans in 
the remote machine. In step 92, the HTML adaptor 34 
is initiated in the virtual machine 22 at the remote station 
20 and in step 94 the bean(s) 29 of that virtual machine 
which are to be accessible remotely are registered with 
the framework, or more particularly with the repository 
service 27 as described above. This means that when 
the HTML adaptor queries the framework 24, the frame- 
work 24, with reference to the repository sen/ice. Is able 
to identify the beans 29 to be accessed and to permit 
access thereto by the HTML adaptor. 
[0063] The HTML adaptor 34 allows communication 
over the network using conventional HTTP exchanges. 
It behaves as an HTTP server. When it receives a re- 
quest, it dynamically generates a page containing a list 
of beans (objects) 29 currently registered with the re- 
pository object 27. 

[0064] A bean is represented in HTML as an HTML 
table wherein: 
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a first column contains a property name; 

a second column contains a property type; 

a third column contains the access right (read/ 

write); 

a fourth column contains a property value. 

[0065] As mentioned above, if the property is read/ 
write, an HTML form is generated. 
[0066] In step 96. the beans are displayed at the client 
station (represented by display 98) using the HTML rep- 
resentation of a bean as described above by accessing 
the HTML page using a conventional web browser 
which communicates with the HTML adaptor using HT- 
TP exchanges. The user is able then to select, at step 
100, a bean using conventional web browser functions. 
The web browser will then issue an HTTP GET request 
to the HTML adaptor 34. The HTML adaptor employs 
introspection to extract the bean properties and then re- 
turns an HTML post response to the browser, whereby 
the browser may display the properties, and possibly al- 
so the actions and events supported by the bean, as 
represented at 1 02. By further use of the browser using 
conventional browser functions, the user is able to se- 
lect and specify modifications to aspects of the bean, for 
example changes to the properties. By a further ex- 
change of HTML GET and/or SET requests and POST 
responses, the web browser and the HTML adaptor are 
able to modify, at step 1 04, the corresponding properties 
of the bean at the remote station and to display these 
changes to the user at the client station. 
[0067] Thus, this mechanism provides a computer- 
Implemented method of accessing from a client ma- 
chine an object such as a bean at a remote machine via 
a telecommunications network by mapping the object to 
an externally accessible machine page at the remote 
machine and browsing the object via the machine page 
using a browser. 

[0068] Another example of the structure shown in Fig- 
ure 3. this time using the representation of Figure 3, is 
shown in Figure 7, where a network management sys- 
tem agent 20 is managed by an SNMP manager appli- 
cation. In Figure 7 like reference numerals relate to like 
features of the arrangement shown in Figure 3. 
[0069] An example of a network management system 
represented in Figure 8 provides an adaptor API to en- 
able Java management applications to communicate 
with the network management system agents. The 
adaptor API provides managed object adaptor clients 
for accessing managed objects through a particular 
communications protocol. The network management 
system defines a representation of m-beans for Java 
management applications and provides a compiling tool 
for generating such a representation automatically from 
an m-bean. A name sen/ice is supplied to allow Java 
management applications to be independent of a par- 
ticular communications protocol. 
[0070] A managed object adaptor client is an abstract 
Java class that enables Java management applications 



to access managed objects. The programmatic repre- 
sentation of the managed object to the Java nnanage- 
ment application is determined by the managed object 
adaptor client. Such a mechanism allows different rep- 

s resentations of the same managed object to be present- 
ed to different Java management applications. The net- 
work management system provides managed object 
adaptor clients for accessing managed objects through 
one or more of the following protocols: RMI; HTTP; and 

10 SSL. 

[0071] The managed object adaptor clients provkJe a 
definition of an adaptor managed object interface. The 
adaptor managed object interface enables Java man- 
agement applications to perform one or more of the fol- 
*5 lowing management operations on a network manage- 
ment system agent: 

retrieve m-beans; 

get or set the properties of remote m-beans; 
call methods of remote m-beans; 
create instances of m-beans; 
delete m-beans; and 

receive events emitted by remote m-beans. 

[0072] A managed object adaptor client provides a 
Java management application with "handles" on rnan- 
aged objects in a remote agent. These handles enable 
the Java management application to manipulate the 
managed objects directly. The Java management appli- 
cation does not need information on the protocol used 
by the managed object All the Java management ap- 
plicatbn needs is the class of object that the managed 
object represents. For example, a Java management 
application for handling accounts uses an abstract class 
for representing accounts. To manipulate an account, 
the Java management application obtains an account 
managed object from the managed object adaptor cli- 
ent. It then casts the account managed object into the 
abstract class that represents the account. In this way, 
the application code is independent of howthe managed 
object is implemented. 

[0073] Figure 8 is a schematic representation of the 
relatbnship between a client bean (c-bean) 54 and an 
m-bean 28. A c-bean 54 is a representation of an m- 
bean to a Java management application. In the pre- 
ferred embodiment of the invention^ a c-bean 54, like an 
m-bean 28, is implemented as a JavaBeans compo- 
nent. A c-bean 54 defines how a Java management ap- 
plicatton accesses an m-bean 28. 
[0074] As seen in Figure 8, a c-bean 54 comprises a 
managed object interface (MO interface) 56 which de- 
fines which of the methods of an m-bean are accessible 
to a Java management application, and a managed ob- 
ject stub (MOStub) 58 that implements the methods de- 
fined in the MO interface 56. 

[0075] A Java management application obtains a ref- 
erence to a c-bean by using an adaptor MO interface 
60. The adaptor MO interface instantiates the c-:bean 
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54. The same implementation of a c-bean 54 can run 
on any managed object adaptor client that Implements 
the adaptor MO interface 60. Different implementations 
of the same managed object can be presented to differ- 
ent Java management applications. Therefore, a single 
m-bean can be associated with several c^beans 54. 
[0076] A Java management application performs 
management operations on an m-bean by calling meth- 
ods of its associated c-bean 54. To the Java manage- 
ment application, a c-bean 54 is a local representation 
of the remote Java object (an m-bean 28). 
[0077] The adaptor MO Interface 60 instantiates the 
c-bean 54. The same implementation of a c-bean can 
run on any managed object adaptor client 62 which im- 
plements the adaptor MO interface 60. Different repre- 
sentations of the same managed object can be present- 
ed to different Java management applications. Thus, a 
single m-bean can be associated with several c-beans. 
[0078] A Java management application performs 
management operations on a m-bean by calling meth- 
ods of its associated c-bean. To the Java management 
application, a c-bean is a local representation of a re- 
mote Java object (an m-bean). 
[0079] Figure 9 is a schematic representation of the 
generation of a c-bean 54 from an m-bean. In an em- 
bodiment of the invention a c-bean is generated auto- 
matically from an m-bean 26 using the Reflection API. 
The generated c-beans exhibit the same properties, 
methods and events as the m-beans. This is the case, 
for example, where no access control policy is enforced. 
[0080] In order to provide the automatic generation of 
a c-bean 54 from an m-bean 28, a compiler 60 takes as 
an input the m-bean 28 and generates as an output the 
MO interface and MO stubs of a c-bean 54. For exam- 
ple, when an m-bean 28 representing a Java class 
named account is compiled, the compiler 60 generates 
an MO Interface 56 named accountMOand a Java class 
named acoountMOSTUB5&, which Implements the ac- 
countMO interface 56. 

[0081] A Java management application can be devel- 
oped using the MO interface definitions. By loading dif- 
ferent stubs, the adaptorMO interface can modify the 
behaviour of the Java management application at run 
time. For example, if read-only stubs are loaded, the 
Java management application will not be able to modify 
the properties in the m-bean 28. 
[0082] The compiler 60 can generate read-only or 
read-write stubs. The generated stubs make use of the 
adaptorMO interface. Therefore, their behaviour is the 
same on any managed object adaptor client that imple- 
ments the adapforMO interface, regardless of the imple- 
mentation of the managed object adaptor client. 
[0083] Figure 10 is a block diagram of steps for ac- 
cessing a bean at a remote (server) station from a local 
management (client) station using a structure as shown 
In Figure 8. 

[0084] The management application (e.g. a Java 
management application) at the management station 



generates, at step 80. a get request to the adaptorMO 
at the client station. The adaptorMO, with the Mostub 
and the network adaptor at the client station generate, 
at 81 , a request in accordance with an appropriate net- 
5 work protocol (e.g. HTTP). 

[0085] Thus the request sent via the network to the 
managed system could, for example, be in the fonn of 
a GET request for a nnanagement property of a man- 
aged object. 

10 [0086] The appropriate managed object adaptor sew- 
er 30-38. depending on the protocol used, receives the 
external request at step 82. It will then access, at step 
83, the framework 24 to get an appropriate method. The 
framework gets, at step 83, a managed object method 
IS for the request and returns, at step 84, the management 
property of the managed object to the adaptor, which in 
turn returns, at step 85. composes a retum message 
with the result in accordance with the same network pro- 
tocol (e.g. HTTP). The result message is received, at 
step 86, at the client adaptor and adaptorMO, which re- 
turns the result to the management application. 
[0087] A name service is provided which allows man- 
agement applications to be independent of a particular 
communications protocol. Java management applica- 
tions use the name service to determine which managed 
object adaptor client to use for accessing an agent. Fig- 
ure 11 is a schematic flow diagram illustrating the oper- 
ation of the name service. 

[0088] In step 62, the management application pass- 
es the identity of the agent to be accessed to the main 
service. 

[0089] In step 64, the name service returns the class 
name of the managed object adaptor client, for example 
sunw.jaw.moa.rmi in the case of an agent access 
through the Java RMI system. 
[0090] In step 66, the Java management application 
uses its default class loader to dynamically bad the 
managed object adaptor client and instantiate It. The 
Java nnanagement application can then interact with the 
agent through the managed object adaptor client, re- 
gardless of the communications protocol. 
[0091] As mentioned above, a management bean, or 
m-bean is a managed object in a network management 
system agent. A managed object is a software abstrac- 
tion of a resource that is controlled and monitored by the 
agent. In an example of a network management system, 
all m-beans are implemented as JavaBeans compo- 
nents. They can be accessed using a conventional Java 
application builder, such as the Java Beans Develop- 
ment Kit. Within an m-bean, it is possible to call and use 
services provided by the network management system. 
[0092] A JavaBeans component includes properties 
which form discrete, named attributes which can affect 
the appearance or the behaviour of the JavaBeans com- 
ponent. For example, an m-bean representing an Ether- 
net driver might have a property named fpackets that 
represents the number of incoming packets. Properties 
can have arbitrary values, including both built-in Java 
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end types and class or interface types such as Java.awt. 
color. Properties are always accessed via method calls 
on the object that owns them. For readable properties 
there is a get method to read the property value. For 
writeable properties, there is a sef method to allow the 
property value to be updated. 
[0093] A default design pattern can be used for locat- 
ing properties: 

public PropertyType get PropertyNameQ: 
public void set PropertyName (PropertyType val- 
ue); 

[0094] If a class definition contains a matching pair of 
get PropertyName and set Prop0/tj»'A/am© methods with 
the return type of the getter corresponding to the param- 
eter type of the setter, then these methods define a read- 
write property. If a class definition contains only one of 
these methods, the name defines either a readonly or 
write-only property called PropertyName. 
[0095] In addition for Boolean properties, it is possible 
to define a get method using the following design pat- 
tern: 

public boolean tsPropertyNameQ; 

[0096] The IsPropertyName method may be provided 
instead of a getPropertyName method where it may be 
provided in addition to a getPropertyName method. 
[0097] An Index property is an array PropertyElement 
[I that is accessed by methods of the form: 

public PropertyElement getPropertyName (int in- 
dex); 

public void setPropertyName (int index, Proper- 
tyElemerit b). 

[0098] If a class definition contains either kind of 
method, PropertyName is an index property These 
methods can be used to read and write a property value. 
These methods can be defined in addition to the meth- 
ods defined for simple properties. Therefore, ah index 
property can be represented by four accessor methods. 
[0099] By default, the following design pattern is used 
to determine which events an m-bean can multicast: 

public void addEventUstenerType(EventLlstener' 
Types): 

public removeEventLi$tenerType(E ver^tUsterter- 
Typea)\ 

[01 00] Both of these methods take the Ever)tListener- 
Typetype argument, where the Ever)tUstenerType type 
extends the ;ava.u///.EvenfL/ster70ririter1ace, where the 
first method starts with add, the second method starts 
with remove, and where the EventListenerType type 
name ends with Listener 

[0101] This design patent assumes that the Java 



bean is acting as a multicast event source for the event 
specified in the EventListenerType interface. 
[01 02] To conform to the JavaBeans model, all public 
methods of a JavaBeans component should be exposed 
5 as external methods within the component environment 
for access by the components. By default, this includes 
property accessor methods, and in the event listener 
registry method. 

[01 03] In addition to the JavaBeans component mod- 
10 el for design pattern elements, the network manage- 
ment system can define an action as a public method of 
an m-bean that makes sense to be called remotely Ac- 
tion facilitates the differentiation of an m-bean public 
method which is exposed for other local m-beans from 
IS public methods that can be called remotely The design 
pattern for an action is as follows: 

public AnyJavaType periomAnAction (AnySigna- 
ture): 

20 

[0104] M-beans can contain native libraries, that is a 
libraiy not written in the language (e.g. Java) of the m- 
bean. The network management system can provide a 
mechanism for loading a native library from the same 
25 remote class server as the m-beans. To enable an m- 
bean to use this mechanism, a static loadLibrary method 
of the Framework class can be called in which the caller 
includes a reference to the Java class of the caller. Such 
information is used by the framework 24 for identifying 
30 the class loader by which the class is loaded. 

[0105] The core management services mentioned 
above are for many of the management operations com- 
mon to all agents, thereby simplifying the development 
of agents. By providing these core sen/Ices, the network 
35 management system enables efforts to be concentrated 
on developing those parts of an agent which are specific 
to a particular application, namely the m-beans and the 
applications to control and manage them. 
[0106] Figure 12 is a schematic flow diagram of the 
40 initialisation of a network management system agent 20. 
The initialisation process comprises: 

in step 70, creating an instance of the framework 24; 
in step 72, adding the m-bean repository service 27; 
45 . in step 74, adding the metadata service 29; and 

in step 76. adding at least one managed object 
adaptor server (30-38) so that the agent can be ac- 
cess by management applications. 

so [01 07] Once the network management system agent 
20 has been initialised, no further management services 
need to be added before an agent is started. These can 
be added dynamically to the agent while it is running. 
[0108] The framework 24, controls the management 
55 services and m-beans of an agent 20 developed using 
the network management system. In the preferred em- 
bodiment it is implemented by the Java class java.jaw. 
agent.cmf. Framework. An agent must contain one in- 
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stance of the framework, that is. in the preferred embod- 
iment, one instance of the java.jaw.agentcmf.Frame- 
worl< class. 

[0109] In the preferred embodiment, m-beans can be 
managed only if they are registered with an object name 
in the m-bean repository 27 of the agent 20. Accordingly, 
the m-bean repository sen/ice 27 is added in step 72 
before the agent 20 becomes operational. The m-bean 
repository sen/ice 27 is used for storing and retrieving 
the association between an m-bean and its object name. 
The m-bean repository sen^ice of the preferred embod- 
iment is defined as the Java interface java.jaw.agent. 
services. MoRepSrvlf. An agent can only be associated 
with the one m-bean repository sen/ice at any one time. 
However, it is possible to change the m-bean repository 
service with which the agent is associated while the 
agent is running. 

[01 1 0] The m-bean repository can be implemented as 
a volatile storage or as a persistent storage. In a volatile 
repository, all the information on m-beans is stored in 
memory. All of the information in a volatile repository is 
lost when the agent is stopped. Accordingly, when an 
agent is started, with a volatile repository, it has to reload 
the information in the repository. With a persistent re- 
pository, all the information on m-beans is stored in a 
database whereby the information in a persistent repos- 
itory is not lost when the agent is stopped. It is also pos- 
sible to implement a mixed repository whereby informa- 
tion on m-beans is stored in memory or in a database. 
[0111] The metadata sen/ice referenced above is 
used to obtain the properties and actions supported by 
an m-bean. A preferred implementation of the metadata 
service is based on the Reflection API provided by the 
known Java Development Kit for performing introspec- 
tion. 

[0112] As mentioned above, at least one managed 
object adaptor sen/ice shouki^ be running in the sen/er 
virtual machine as the network management system 
agent. The network management system does not re- 
quire a managed object adaptor server to conform to a 
specific interface definition or implementation. The man- 
aged object adaptor sender is arranged to access the 
framework 24 to retrieve and change informatbn con- 
tained In the agent. The managed object adaptor send- 
ers provided are implemented as m-beans. Examples 
of managed object adaptor servers have been de- 
scribed above. In the preferred embodiment of the In- 
vention, the managed object adaptor sen/ers are imple- 
mented as appropriate Java classes. 
[01 1 3] For example, an RMI managed object adaptor 
server can be implemented as a Java class sunw.jaw. 
agent.adaptor.rmi.AdaptorSen/erlmpl. It enables Java 
management application to access an agent using the 
Java remote method invocation (Rl\^l) system. As de- 
scribed above, a Java management application access- 
es this server through a managed object adaptor client 
implemented as the Java class sunw.jaw.agent.adaptor. 
rmi.AdaptorClient. 



[0114] Core nnanagement sen/ices can be added to 
an agent while it is running, once the agent has been 
initialised as described above, it is possible to add a core 
service to an agent in either of the following ways: 

5 

directly calling a set method for the service within 
the Framework class; 

adding the sen/ice to the m-bean repository In the 
same way as for an m-bean. 

10 

[0115] Adding a core management service directly 
gives faster perfomnance than adding a core manage- 
ment service to the m-bean repository. This is because 
the framework does not need to query the m-bean re- 
15 posltory in order to obtain the service. However, certain 
restrlctbns can apply to a core management service 
that has been added directly: 

the service is not visible to remote applications; and 
20 • it is not possible to store information on the service 
in persistent storage. 

[0116] Accordingly, where it is desirable for a core 
management service to be visible to remote applica- 
tions, it is necessary to add the service to the m-bean 
repository. If it is desired to store information on a core 
management sen/Ice In persistent storage, It is also nec- 
essary to add the service to the m-bean repository. The 
m-bean repository to which the service is added, must 
support persistent storage. 

[0117] A Class Sen/ice Name contains names by 
which the framework 24 identifies the sen^ices that are 
implemented for an agent. The framework 24 retrieves 

the sen/ice it requires as follows: 

1 . The framework 24 checks if a service has been 
defined using a direct set method. If a sen/ice has 
been defined in this way, the framework 24 uses this 
sen/ice. 

2. If the service has not been defined using a direct 
set method, the framework queries the m-bean re- 
pository to obtain all the m-beans that are instances 
of the class that Implements the sen/ice. For exam- 
ple, for the metadata sen/ice, the framework 24 
queries the m-bean repository to obtain all the in- 
stances of the class named ServiceName.META. 

if the repository contains several Instances of 
the class, the framework 24 uses the first in- 
stance returned by the m-bean repository, 
if the m-bean repository contains no instances 
of the class, the framework throws a Servlce- 
NotFound Exception. 

55 [0118] Various operations can be performed in a net- 
work management sen/ice agent. For example, an ob- 
ject in an agent can use core management sen/k:es for: 
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instantiating m-bean; 

registering m-beans with the m-bean repository; 
retrieving m-beans from the m-bean repository; 
getting and setting the values of properties within 
m-beans; and 5 
defining relationships between m-beans. 

[01 19] An object name uniquely identifies an m-bean. 
Management applications use object names to identify 
the m-beans on which to perform management opera- io 
tions. Any naming scheme could be used. For example, 
In the preferred embodiment of the Invention, a naming 
scheme defined by Microsoft Corporation for the Hyper 
Media Management Scheme (HMMS) could be used. 
[0120] In order to instantiate an m-bean, one of the is 
following methods of the Framework class can be 
called: 

newObject to user default storage mechanism for 
storing the m-bean; 20 
newDBObject to specify the m-bean is persistent. 

[0121] With either of these methods, it is necessary 

to provide: 

25 

the Java class of the m-bean to be instantiated; and 
the object name to be used for registering the m- 
bean. 

[0122] By default, the framework 24 uses the default 30 
class loader to locate the Java class of the m-bean to 
be created. It then creates an Instance of the class. 
Once the m-bean has been instantiated, it is initialised 
and registered so that it is accessible to the framework 
24. It is possible to initialise and register an m-bean by 3S 
using: 

a method defined in the m-bean itself; or 
the framework 24. 

40 

[0123] For initialising a register of an m-bean using a 
method defined in the m-bean itself, the Java class def- 
inition of the m-bean should contain: 

an initialisation method; ^ 
the code required to enable the m-bean to register 
itself with the m-bean repository. 

[0124] Once the m-bean has been Instantiated, the 
framework 24 uses the metadata service 27 to find the so 
initialisation method in the newly created m-bean. If 
such a method is present in the m-bean, the framework 
24 calls it giving: 

a reference to itself as a first parameter; ss 
the object name for use in registering the m-bean 
as a second parameter. 



[0125] The m-bean is therefore able to register itsetf 
with the m-bean repository using the code provided. 
[0126] If an m-bean is not provided with the initialisa- 
tion method, the framework initialises and registers the 
m-bean using functions provided for this purpose. 
[0127] Registering a JavaBeans component with the 
m-bean repository 25 enables the component to be 
managed by the agent 20. Registering the JavaBeans 
component does not require modification of code within 
the JavaBeans component itself. Instead, all that is re- 
quired is the additbn of code for registering it in the m- 
bean repository. Therefore, it is possible to register any 
existing JavaBeans component in the m-bean reposi- 
tory. Once registered, the agent 20 manages the Java- 
Beans component in the same way as any m-bean. 
When an m-bean is registered, it is assigned an object 
nanie. An object name can be explicitly specified. If an 
object name is not explicitly specified, the framework 24 
assigns a default name to the m-bean. 
[0128] The network management system provides 
services for retrieving.m-beans from the m-bean repos- 
itory. These services enable the retrieval of m-beans us- 
ing: 

pattern matching on the object name; or 

queries (filters) on the Java properties they contain. 

[01 29] By using pattern matching on the object names 
of m-beans, it is possible to retrieve: 

- a specific m-bean using its full object name; 

a set of m-beans sharing the same bgical class as 
expressed in the object name; 
a set of m-beans sharing the same domain name; or 
all the m-beans contained in an agent. 

[01 30] Using queries enables the retrieval of m-beans 
according to Java properties and their values within m- 
beans. The m-bean repository evaluates properties if it 
is able to do so. Othenwise the framework evaluates 
queries itself. To determine whether a repository is able 
to assess queries, the framework causes a query meth- 
od for this purpose. 

[0131] The network management system provides 
services for getting and setting properties of m-beans. 
If the agent provides a metadata service, in a call to the 
get or set method of the m-bean, all that needs to be 
supplied are: 

the name of the property to be retrieved or set; 
the object name of the m-bean that contains the 
property. 

[01 32] If the agent does not provide a metadata sen^- 
ice, it is still possible to call directly to the get or set meth- 
od of an m-bean. In this case it is also necessary to sup- 
ply to the caller the name and signature of the method 
to call. 
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[0133] A relationship service enables relationships 
between m-beans to be defined when they are required. 
The relationships do not need to be defined in advance. 
Information on the relationships between m-beans is not 
stored with the m-beans themselves, but is stored with 
the relationship. A relationship needs to be registered 
with the m-bean repository. A relationship is defined by: 

a set of roles, for example in an ownership relation- 
ship a person owns a book and a book is owned by 
a person; 

- a degree which corresponds to the number of re- 
quired roles in a relationship. 

[01 34] The m-beans involved in a relationship are re- 
ferred to in a relationship by their object names. A spe- 
cific class loader can be added to the agent at start-up 
or while the agent is running. It is possible to have sev- 
eral class loaders within the same agent, provided that 
they are all registered with the m-bean repository. When 
the creation of a new object is requested, it is possible 
to specify the class toader to be used for loading the 
object. In this case the class loader is identified by its 
object name. The system provides several implementa- 
tions of a network class loader, each implementation us- 
ing a different protocol and requiring a different class 
server. 

[0135] The system provides event handling services 
for filtering, logging and fonwarding events through dif- 
ferent communications protocols. To emit an event, a 
send event method is called. When this method is 
called, the framework 24 retrieves all the m-beans cor- 
responding to an event handling service and calls an 
event handling method of each event handler retrieved. 
This method is responsible for handling the events. 
[0136] Figure 9 is a schematic representation of the 
compiling of a c-bean 54 from an m-bean 28. The com- 
piler 60 implements one translation scheme for gener- 
ating c-beans. It is, however, possible to implement dif- 
ferent translation schemes depending on the require- 
ments. 

[0137] Figure 13 illustrates an example of the output 
of the compiler 60 for compiling a single m-bean called 
A. Figure 14 shows the output of the compiler 60 if a 
compiled m-bean includes aListenerior a specific event 
AnEvent 

[0138] Thus, if the m-bean contains listeners, the 
compiler 60 generates: 

a Java interface for the listener to be included in the 
MO interface; 

a listener stub which is an implementation of the m- 
bean listener for catching m-bean events and for- 
warding them to the framework 24; and 
a Java management application's view of the event 
associated to the listener referred to as EventMO. 

[0139] The compiler 60 parses an m-bean using the 



applicable design parameters. After parsing, the com- 
piler 60 uses a number of rules for generating the c- 
bean. 

[0140] Each property of the m-bean will be present in 
s the c-bean with the same accessor methods. So, if a 
property is read-only in the m-bean, the property will be 
read-only in the c-bean. 

[01 41 ] Figure 1 5A is an illustration of a simple c-bean 
which is generated when compiling an m-bean defined 

70 by a code example shown in Figure 1 5B. In additton, the 
compiler 60 generates a file containing an implementa- 
tion of the Simple MO interface. 
[0142] In addition to the property accessors, the com- 
piler 60 generates code only for public methods for 

'5 which it makes sense to provide remote access. Other 
public methods do not appear in the c-bean generated 
by the compiler 60. 

[01 43] Figure 1 6A shows a subset for an action meth- 
od in a c-bean of the MO interface which the compiler 
20 60 will generate when compiling the action method in 
an m-bean defined as in Figure 16B. 
[0144] If an m-bean contains a listener called A, the 
compiler 60 includes a listener called AlfMO in the c- 
bean. 

25 [0145] When using the c-bean. an application will 
have to implement the Aif mo interface to add or remove 
the listener in the c-bean. Generally, a listener is an in- 
terface containing a certain number of methods. Each 
method has one input parameter. The input parameter 
30 extends an event object concerned. 

[01 48] In an example, each method defined in listener 
A refers to an event object whk;h, for the purpose of this 
example is called AnEvent. Accordingly in the Aifmo in- 
terface, the event object Is called AnEventMO. Thus, for 
3S a listener A, the compiler 60 generates files: 

Atfmo.java; 
AnEventMO.java. 

40 [0147] In addition, the compiler 60 generates an im- 
plementation of listener A named AStub.java. 
[01 48] Codes generated by the compiler 60 complies 
with the design parameters designed by the JavaBeans 
component model. Accordingly, the objects generated 

^ by the compiler 60 can be integrated in development en- 
vironments that comply with this model. In addition, the 
compiler 60 adds some public methods which do not fol- 
low the design patterns defined by the JavaBeans com- 
ponent model. The added methods are designed to limit 

so the network traffic between an m-bean and a c-bean. 
For example, by calling one function on a c-bean, it is 
possible to read all the properties of the corresponding 
m-bean. 

[01 49] The compiler 60 generates Java source code. 
55 It is possible to edit the generated code and modify it to 
define a specific view of an m-bean. I nstead of modifying 
both the interface and the stub, it is better to keep the 
interface and modify only the stub. The code generated 
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by the compiler 60 enables an application to be built us- 
ing the Interface. At one time the behaviour will change 
depending on which stubs are loaded by the adaptor- 
MO. For instance, the compiler can generate readonly 
or read-write stubs for the same Interface. Accordingly, 
an m-bean browser can be developed based on the in- 
terface. As mentioned above, the browser will thereby 
have a different behaviour depending on whether the 
read-only or read-write stubs are loaded. 
[0150] The adaptorMO interface is a Java interface 
defined for managing the agent 20. The network man- 
agement system provides several implementations of 
the adaptorMO interface based on different communi- 
cations protocols, as described above. However, the 
adaptorMO interface is protocol independent. Accord- 
ingly, any piece of code written using the interface can 
run on any of the implementations provided by the net- 
work management system. 

[0151] Within the adaptorMO interface there are two 
different levels. A low level where remote objects Cm- 
bean) are manipulated using their names, and a high 
level where remote objects (m-bean) are manipulated 
using a local view (c-bean) of the remote objects. The 
high level is built on top of the low level interface. 
[0152] Using the low level interface is practical for 
building generic applications (such as an HTML object 
viewer or MIB browser). Using the high level interface 
is much easier than using the lower level interface. How- 
ever, it means that the application knows the semantic 
of the c-beans it manipulates. In addition, it requires the 
application (or the adaptorMO interface) to have access 
to MOs and MOStubs. A first step in initialising an adap- 
tor consists of initialising an implementation of the adap- 
torMO interface. 

[0153] In order to initialise an adaptor, the client ap- 
plications invokes a "connect" method defined in the 
adaptorMO interface. Parameters are provided which 
relate to the host name of the agent, the port number to 
use and a logical name which is generally dependent 
on the underlying communication mechanism. The dif- 
ferent piece of information could be obtained from a 
name server or directory service at the same time the 
implementation name of the adaptor to use is given. De- 
pending on the underlying communication mechanism 
used by the adaptorMO interface, the call to "connect" 
might not involve any message exchange between the 
client and agent. 

[0154] An adaptor makes use of: 

a name server for getting the Java class name for 
use for representing a specific m-bean (known 
. through its object name); 
- a class loader for loading c-beans. 

[0155] If all the Java classes for the c-beans are 
present on the machine where the client application is 
running, there is no need to use a specific class loader. 
Othenvise, it is possible to use a network class loader 



for getting the classes over the network. 
[0156] For using a network class bader, a client ap- 
plication needs to instantiate the network class loader 
When instantiating the object, the application provides 
5 an object name. The object name can contain any do- 
main and any class name. However, the object name 
should contain the following key properties: 

host (the host name where the class server is run- 
10 ning); 

- port (the port number to use); 

service (the name of the RMI sen/ice to invoke). 

[0157] Once an adaptor is initialised, the application 
IS Is ready to perform management operations on the re- 
mote agent. An application can retrieve a subset or all 
of the m-beans managed by an agent. When retrieving 
objects, an application can specify queries. The results 
of the retrieval can be obtained under two different 
20 schemes: 

a list of object names (represented by a Vector); 
a list of c-beans (for each object name retrieved the 
adaptor will instantiate a c-bean). 

2S 

[01 58] In order to read a property of a remote m-bean, 
the property name is needed when using the low level 
adaptorMO interface level. When using the high level 
interface, the c-bean is retrieved and then a getter as- 

30 sociated to the property is invoked. 

[01 59] Setting a property of a remote m-bean, a prop- 
erty name and the property object type is required when 
using the low level adaptorMO interface level. When set- 
ting a value, it is possible to specify the name of an op- 

35. erator class. On the agent side, the specified operator 
is instantiated and invoked for setting the property value. 
When using the low level adaptorMO interface level, it 
is possible to set several properties through one method 
call using a list of modifications. 

^0 [0160] When using the high level adaptorMO inter- 
face level, a c-bean is obtained and the developer then 
invokes the set associated to the property. 
[01 61 ] Through the adaptorMO interface, it is possible 
to request Instantiated of m-beans within a remote 

^ agent. When requesting the instantiation, it is possible 
specify a new class loader through which the agent is 
supposed to load the new class to instantiate. The class 
bader can be specified using its object name. If no class 
loader is specified, the agent uses the default class load- 

50 er. When instantiating a remote m-bean, it is possible to 
directly obtain a c-bean for representing the newly cre- 
ated m-bean. If no name is provided and if a name serv- 
er is specified, the adaptor queries the name server in 
order to obtain the name of the Java class to instantiate 

55 on the agent's side. Otherwise, it is the responsibility of 
the agent to determine the class name of the class to 
instantiate. When instantiating an m-bean in the agent, 
it is possible to explicitly request the object to be per- 
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sistent. 

[01 62] Through the adaptorMO interface, it is possible 
to transfer Java objects from the client to the agent. In 
order to do this, the adaptorMO interface serialises the 
object, sends the object over and deserialises the object 
in the agent. 

[0163] Through the adaptorMO interface, It is also 
possible to remove an m-bean object from the remote 
agent. The m-bean is not removed from the virtual ma- 
chine, but only from the object repository of the agent. 
[0164] Figure 17 is a flow diagram giving an oven/iew 
of the steps in creating and operating a management 
system as described above including steps of defining 
a network management model including at least one 
management bean using a bean-based environment 
and compiling said mcdel to Implement said computer 
network management system In said bean-based envi- 
ronment. 

[0165] !n step 110. a model is created using a bean- 
based environment. A preferred bean-based environ- 
ment is Java environment with the beans being Java- 
Beans. 

[0166] As mentioned above, beans provide a set of 
properties, a set of methods for performing actions, and 
support for events and for introspection. Conventionally, 
the properties allow beans to be manipulated program- 
maticalfy and support customization of the bean, the 
methods implement the properties and the support for 
events enables beans to fire events and define the 
events which can be fired. The support for introspection 
enables the properties, events and methods of the bean 
to be inspected from externally. 
[0167] Accordingly, step 110 Includes generating at 
least one said management bean providing at least one 
property for modelling a property of a managed re- 
source, and/or a method for modelling an action for said 
managed resource and/or support for at least one event 
for modelling an event of said resource and/or support 
for introspection permitting external analysis of the com- 
position of said bean. This step also includes defining 
the relationship and interactions between management 
beans as representative of the relationships and inter- 
actions between the managed resources. This step can 
also include defining at least one listener event in re- 
spect of at least one management bean. 
[0168] It is recognised for the first time in respect of 
the present network management system that beans 
can be used beyond their conventional role to provide 
a management vehicle (management bean) for directly 
modelling resources to be managed. For example, a 
property in a management bean can be used for mod- 
elling a property (e.g. a resource attribute such as the 
size of a memory, the number of messages received in 
a buffer, etc) of a managed resource. A method of a 
management bean can be used for modelling an action 
(e.g. a system rest) of a managed resource. A bean can 
also be used to provide support for an event (for exam- 
ple a disk full event) for a nnanaged resource. For ex- 



ample, a management bean can provide support for a 
listener event, whereby one management bean can be 
responsive to an event on another management bean. 
By means of the support for introspection a manage- 
s ment bean can permit external analysis of the compo- 
sition of the bean and the exchange of information be- 
tween beans. Management beans can include defini- 
tions of relationships and interactions between manage- 
ment beans as representative of the relationships and 
10 Interaction between the managed resources. 

[0169] As beans are reusable software components 
which can be manipulated visually In a builder tool (e.g. 
an editor or graphical user interface builder (GUI build- 
er)), in step 110 a user can use a conventional builder 
IS tool, such as the JavaBeans Development Kit. for gen- 
erating the management system model Including beans 
defining system resources, their functions and the rela- 
tionships between and interactions of the system re- 
sources. The bean model is defined within a virtual ma- 
chine forming the bean-based environment, for example 
a model using JavaBeans within a Java virtual machine. 
This greatly facilitates the generation of the manage- 
ment system model. Verification and debugging of the 
model can be readily performed using Introspection and 
other techniques. 

[0170] In step 112, once the model has been gener- 
ated, the nrKxJel can be compiled directly using a con- 
ventional compiler for the bean-based environment, for 
example the compiler 60 shown in Figure 9. By defining 
a model in a bean-based environment, it is possible di- 
rectly to compile the bean-based model to form a bean- 
based Implementation using a standard compiler for the 
bean -based environment, for example by compiling the 
JavaBeans using a Java compiler. Accordingly, the re- 
sulting bean management system is also defined within 
the same Java environment. This greatly simplifies this 
stage of the generation of management system as the 
compiler forces a reliable and homogeneous Implemen- 
tation of the model. 

[0171] At runtime, therefore, in step 114, the manage- 
ment system described earlier in this document pro- 
vides a robust and readily modifiable structure, without 
the difflcuttles and disadvantages of prior network man- 
agement system. 

[0172] Step 114 includes the steps described in re- 
spect of Figure 12 of registering one or more manage- 
ment bean(s) with the extensible agent framework; reg- 
istering one or more network adaptor(s) (e.g. network 
adaptor bean(s)) for a network communications protocol 
with the extensible agent framework; and enabling ex- 
ternal access via the network to the management bean 
(s) via the network adaptor(s). 
[0173] As described with respect to Figure 1 2. the ex- 
tensible agent framework can include an associated re- 
pository bean and the steps of registering one or more 
management bean(s) and/or network adaptor(s) can 
comprise registering one or more management bean(s) 
and/or network adaptor(s) with the repository bean. 
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[0174] There has been described (see. inter alia, the 
description of Figures 5 and 6), a computer-implement- 
ed method of accessing from a client machine an object 
such as a bean at a remote machine via a telecommu- 
nications network. The method includes mapping the 
object to an externally accessible machine page at the 
remote machine and browsing the object via the ma- 
chine page using a browser. The method can include 
steps of: initiating a network adaptor at the remote ma- 
chine; registering the object with an agent framework; 
causing the network adaptor to query the agent frame- 
work to identify registered objects; accessing the page 
by means of the browser; and selecting the object from 
the accessed page. 

[0175] In particular, there has been described (see, 
inter alia» the description of Figures 5 and 6) such a 
method including steps of: registering the bean at the 
remote machine, for example with an agent framework 
at the remote machine; generating a machine page, for 
example an HTML page at the remote machine, which 
page contains the registered bean; and browsing the 
bean via a network adaptor and the machine page at 
the remote machine using a browser at the client station. 
Where the bean has a read-write property, an HTML 
form can be generated. The network adaptor can be ar- 
ranged to query the framework to identify the registered 
bean, possible via an repository with which all beans are 
registered. The interaction with the beans may be ef- 
fected by: displaying at a client machine representations 
of remotely modifiable beans; responding to user selec- 
tion of displayed bean representations to display bean 
properties which are remotely modifiable; and respond- 
ing to user input remotely to modify selected parameters 
of the bean. 

[0176] Moreover, there has been described a system 
and mechanism whereby remote bean access is provid- 
ed by mapping beans onto an HTML page at the network 
statbn at which the beans are located. An HTML gen- 
erator running on the same virtual machine is used dy- 
namically to map the beans onto the HTML page. Re- 
mote access for browsing and modifying the beans is 
then possible using a web browser supporting HTTP or 
HTML protocols. An application of the remote bean ac- 
cess method is in the context of a network agent for a 
network management system. 
[0177] It will be appreciated that although particular 
embodiments of the Invention have been described, 
many modifications/additions and/or substitutions may 
be made within the scope of the present invention. 

Claims 

1. A computer-implemented method of accessing 
from a client machine an object at a remote machine 
via a telecommunications network, the method 
comprising steps of: 



a) registering at least one said object at said 
remote machine; 

b) generating a machine page at said remote 
machine, which page contains at least one said 

s registered object; and 

b) browsing said at least one object via a net- 
work adaptor and said machine page at said re- 
mote machine using a browser at sakJ client 
station. 

10 

2. The method of Claim 1, wherein said remote ma- 
chine comprises an agent framework and wherein, 
in step (b), said network adaptor queries said frame- 
work to identity said at least one registered object. 

75 

3. The method of Claim 2, wherein said framework 
comprises an associated repository object and 
wherein step (a) comprises registering said at least 
one object and/or said network adaptor with said re- 

20 pository object. 

4. The method of Claim 2 or Claim 3. wherein said 
framework is a bean and/or said network adaptor is 

a bean. 

2S 

5. The method of any preceding claim, wherein said 
object is a bean comprising a set of properties, a 

set of methods for performing actions, and support 
for events and for introspection. 

30 

6. The method of Claim 4 or Claim 5, wherein step (b) 
comprises extracting bean methods by introspec- 
tion. 

3S 7. The method of any preceding claim, wherein saki 
object is a managed object bean. 

8. The method of any preceding claim, wherein saki 
object is one of a set of beans at said remote ma- 

<o chine and wherein step (d) comprises: 

- displaying at a client machine representatbns 
of beans at said remote machine which are 
modifiable remotely from said client machine; 

45 - responding to user selection at said client ma- 
chine of a displayed bean representation to dis- 
play at said client machine bean properties 
which are remotely modifiable; and . 
responding to user input at said client machine 

so remotely to wo6\iy selected parameters of said 

bean. 

9. The system of any one of Claims 4 to 9, wherein 
said machine page is an HTML page and said bean 
Is represented as an HTML table wherein: 

a first column contains a property name; 
a second column contains a property type; 
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a third column contains tlie access right; and 
a fourth column contains a property value. 

10. A computer-implemented method of accessing an 
object at a remote machine via a telecommunica- 
tions network, said method comprising steps of: 

mapping said object to an externally accessible 
machine page at said remote machine; and 
browsing said object via said machine page us- 
ing a browser. 

11 . The method of Claim 10. wherein said mapping step 
comprises: 

initiating a network adaptor at said remote ma- 
chine; 

registering said object with an agent frame- 
work; and 

- causing said network adaptor to query said 
agent framework to identify registered objects. 

12. The method of Claim 10 or Claim 11, wherein said 
browsing step comprises: 

accessing said page by means of said browser; 
selecting said object from said accessed page. 

13. The method of Claim 12, wherein said browsing 
step additionally comprises modifying said selected 
object. 

14. The method of any one of Claims 10 to 1 3, wherein 
said object is a bean comprising a set of properties, 
a set of methods tor performing actions, and sup- 
port for events and for introspection. 

16. The method of Claim 14, wherein said machine 
page is an HTML page and said network adaptor is 
an HTML adaptor. 

16. A computer system accessible remotely via a tele- 
communications network, said computer system 
comprising a mapping mechanism configured to 
map an object to an externally accessible machine 
page at said remote machine, whereby said object 
is accessible externally via said machine page us- 
ing a browser. 

17. The system of Claim 16, wherein said mapping 
mechanism comprises: an agent framework and a 
registration mechanism for registering said object 

. with said agent framework. 

18. The system of Claim 16 or Claim 17, comprising a 
network adaptor configured to query said frame- 
work to identify registered objects. 



19. The system of Claim 18, wherein said registration 
mechanism comprises repository object with wh ich 
said object and/or said network adaptor is regis- 
tered. 

5 

20. The system of Claim 1 9, wherein said object is a 
bean comprising a set of properties, a set of meth- 
ods for performing actions, and support for events 
and for introspection. 

10 

21. The system of Claim 20, comprising a browser for 
remotely accessing said bean via said machine 
page. 

^5 22. The system of Claim 21 , wherein said browser per- 
mits selection of said bean from said machine page. 

23. The system of Claim 22, wherein said browser ad- 
ditionally permits modification of said selected 

20 bean. 

24. Thesystemof any one of Claims 16 to 23, wherein 
■ said object comprises a set of properties, a set of 

methods for performing actions, and support for 
2S events and for introspection. 

. 25. The system of any one of Claims 1 6 to 24, wherein 
said page is an HTML page and saki mapping 
mechanism is an HTML adaptor. 

30 

26. The system of any one of Claims 16 to 25, wherein 
saki mapping mechanism comprises software 
mechanism. 

3S 27. A software system on at least one storage device 
for enabling remote access to an object via a tele- 
communications network, said system comprising: 

a mapping mechanism configured to map an 
40 object to an externally accessible machine 

page, whereby said object can be accessed via 
said machine page using a browser. 

28. The system of Claim 27, wherein said object is a 
45 bean comprising a set of properties, a set of meth- 
ods for performing actions, and support for events 
and for introspection. 
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package sunw.jaw.example. mo. Simple; 

* Generated by mogen Compiler version; 
@ (#) Main.java 1.11 97/05/1 6 SMI 

"/ 

import java.jawxommon.*; 
import java.javy.clientmo.*; 

public interface SimpleMO extends ManagedObject { 
public String getStateQ 
throws InstanceNotFoundException, CommunicationException, 
lllegalAccessException, ServiveNotFoundException, 
PropertyNotFoundException; 

public Integer getNbChanges () 
throws InstanceNotFoundException. CommunicationException, 
lllegalAccessException, ServiceNotFoundException, 
PropertyNotFoundException; 

public void setState (String value) 
throws InstanceNotFoundException, CommunicationException. 
lllegalAccessException, ServiceNotFoundException. 
PropertyNotFoundException. InvalidPropertyValueException. 
InstantiationException. ClassNotFound Exception; 

} ^ 

FIG. 15A 
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package sunwjaw.example.mo.Simple; 
/** 

* Very simple of definition of a Beans MO 

^ No special import required. 

*/ 

public class Simple implements java.io.Serializable { 
private String state; 
private Integer nbChanges; 

public Simple () { 

state = "construct"; 
nbChanges = new Integer (0); 

} 

public String getState () { 
return (state); 

} 

public void setState (String s) { 
state = s; 

nbChanges = new Integer (nbChanges.intValue () + 1); 

} 

public Integer getNbChanges () { 
return (nbChanges) ; 

} 



FIG. 15B 
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public interface simpleMBeanMO extends ManagedObject { 
•••• 

public Boolean performReverse (integer pO) 

throws InstanceNctFoundException. CommunicationException, 
IliegalaccessException. ServiceNotFoundException, 
NoSuchMethodException; 

public void performReverse 

throws InstanceNotFoundException, CommunicationException, 
lllegalAccessException, ServiceNotFoundException, 
NoSuchMethodexception; 

•••• 

) 

FIG.16A 



public class simpleMBean implements java.io.Serializabie { 

public void performReverse () { 

StringBuffer buf = new StringBuffer (name); 

name = buf. reverse O-toString {); 

} 

public Boolean performReverse (Integer nPirst) { 
StringBuffer buf = new StringBuffer (); 
int n = nFirstintValue (); 

if (name. length 0<n + 1){ 
return (new Boolean (false)); 

} 

buf.append (name. substring (0, n)); 

name = new String (buf.reverse ().toString () + 
name.substring (n)); 

return (new Boolean (true)); 

} 

••• 



FIG. 168 
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GENERATE A BEAN 
MODEL OF A SYSTEM 
TO BE MANAGED 
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COMPILE THE BEAN 
MODEL TO GENERATE 
A MANAGEMENT 
SYSTEM 
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RUN THE 
BEAN-BASED 
MANAGMENT SYSTEM 
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FIG. 17 
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